```
學號:110368151
一、實驗名稱
     FIR Filter
二、實驗目的
     用 verilog 寫出 FIR Filter
三、實驗過程
     先寫出一個 Filter 再把它們串接起來
四、程式撰寫
     module FIR(clk,reset,x,y);
     input [7:0]x;
     input clk, reset;
    output [7:0]y;
wire [7:0]d1,d2,d3;
wire [7:0]m1,m2,m3,m4;
wire [7:0]d11,d12,d13;
parameter a0=3'b001;
parameter a1=3'b010;
parameter a2=3'b011;
     parameter a3=3'b100;
     assign ml=x*a0;
     dff u2(clk,reset,x,d11);
     assign m2=d11*a1;
     assign dl=m1+m2;
     dff u4(clk,reset,d11,d12);
     assign m3=d12*a2;
assign d2=d1+m3;
     dff u6(clk,reset,d12,d13);
assign m4=d13*a3;
     assign y=d2+m4;
     endmodule
     module dff(clk,reset,d,q);// sub module d flipflop
     input clk, reset;
     input [7:0]d;
     output [7:0]q;
reg [7:0]q;
     always@(posedge clk,posedge reset)
     begin
     if(reset)
     q=0;
     else
     q=d;
```

endmodule

end

## 五、模擬解果與分析 (附圖)



## 六、心得

這是我第一次寫 verilog,覺得他跟一般的程式碼有很大的不同是,他不需要有順序性和需要明確的定義腳位,所以他的思考方法比較不相同。而這次的電路相對簡單,所以是蠻好寫的。如果下次需要寫較大的程式的話應該還是要去好好了解如何去有效率的規劃。